Method and system for joint decision feedback equalization and complementary code key decoding using a trellis

ABSTRACT

A method and system for performing joint equalization and decoding of Complementary Code Key (CCK) encoded symbols. The system comprises: a decision feedback equalizer (DFE) structure for simulating an inverse communications channel response and providing an output comprising an estimation of the received symbols, the DFE structure including a forward equalizer path and a feedback equalizer path including a feedback filter; and, a CCK decoder embedded in the feedback path and operating in conjunction with a feedback filter therein for decoding the chips based on intermediate DFE outputs including those chips corresponding to past decoded CCK symbols. Decisions on a symbol chip at a particular time are not made until an entire CCK codeword that the chip belongs to is decoded, thereby reducing errors propagated when decoding the symbols. Advantageously, the trellis decoding method is implemented as a computationally efficient 64-state trellis.

CROSS-REFERENCE TO RELATED APPLICATIONS

[0001] This application is related to applicant's co-pending U.S. patent application Ser. No. 09/107,546 filed Jun. 30, 1998 entitled METHOD AND DEVICE FOR IMPROVING DFE PERFORMANCE IN A TRELLIS-CODED SYSTEM, the whole contents and disclosure of which is incorporated by reference as if fully set forth herein.

BACKGROUND OF THE INVENTION

[0002] 1. Field of the Invention

[0003] This invention generally relates to digital communication systems, and more specifically, to an enhanced system and method for performing feedback equalization and complementary code key (CCK) decoding using a trellis structure.

[0004] 2. Prior Art

[0005] In many digital communication scenarios (e.g. telephone transmission, broadcast TV transmission, cable etc.). The transmitted signal arrives at the receiver through more than one path in addition to the direct path. This condition is called “multipath” and leads to intersymbol interference (“ISI”) in the digital symbol stream. This ISI is compensated for in the receiver through an equalizer which in many cases is a DFE as shown in FIG. 1. U.S. Pat. No. 5,572,262 shows one method of combating these multipaths.

[0006] A DFE 10 (FIG. 1) has two filter sections, a forward filter 12 and a feedback filter 16. The input to the forward filter 12 is the received data which includes the transmitted symbol sequence a_(k), noise n_(k) and multipath h_(i). The input to the feedback filter is the quantized equalizer output â_(k). The output of both the sections are summed 18 to form the final equalizer output ã_(k) 19 which is also the input to the next stage in a trellis-coded system, the trellis decoder. While a DFE performs better than a linear equalizer in severe ISI, the performance is limited by error propagation through the feedback filter 16 of the DFE 10. Error propagation occurs in the feedback filter 16 when the quantized equalizer output â_(k) is not the same as the transmitted symbol a_(k). If an error is made in determining the symbol â_(k) at the output of the slicer 14, this incorrect symbol is fed back to the input of the feedback filter 16 and propagates. As known, the slicer 14 quantizes the filtered signal, providing an estimate of the symbol received. In many systems which employ error correction codes like trellis codes and/or Reed-Solomon codes to obtain very low error rates at moderate SNRs, the “raw” symbol error rate (SER) at the equalizer output can be extremely high. For example, in a Vestigal Sideband (VSB) system, at threshold in white noise the SER at the equalizer output is about 0.2. The increased error propagation due to these high SERs can cause the DFE to lose a couple of db in performance as compared to the case of no error propagation. Additionally, the error propagation causes the error sequence at the equalizer output to be correlated, since it depends on past incorrect symbol decisions. This correlation has an adverse effect on the subsequent trellis decoder which is usually designed for a white noise sequence.

[0007] According to the IEEE 802.11b high-rate wireless communications standard implementing direct sequence spread spectra techniques, bit stream data may be encoded using a standard known as Complementary Code Keying (CCK). This CCK encoding scheme is used to achieve 5.5 Mbps or 11 Mbps in wireless LANs. Rather than using the Barker code, which is the standard 11-bit chipping sequence used to encode data bits, CCK requires that data be encoded using a series of codes called Complementary Sequences. Because there are 256 unique code words that can be used to encode the signal, up to 8 bits can be represented by any one particular code word (assuming an 11 Mps bit stream).

[0008] It is the case that, for most symbol modulation schemes, the Decision Feedback Equalizer adequately performs notwithstanding the difficulty of providing symbol estimates â_(k). This is because the estimation is done on a symbol-by-symbol basis.

[0009] It would be highly desirable to provide a DFE that exploits the fact that when a symbol is received, there is a relationship between the other symbols before and after it, e.g., if it is in the middle of a CCK code word.

[0010] Past efforts have relied upon providing equalization first and, then perform the CCK decoding. However, it would be highly desirable to provide both CCK modulation decoding and equalization at the same time.

SUMMARY OF THE INVENTION

[0011] An object of this invention is to provide an improved system and method for decoding CCK-encoded digital data streams implementing a trellis-decoding technique.

[0012] Another object of the present invention is to provide an improved receiver device for use in digital communication systems implementing the IEEE 802.11b high rate digital communications standard that implements a novel, computationally efficient trellis decoding technique for decoding CCK encoded symbols.

[0013] These and other objectives are attained with a method and system for performing joint equalization and decoding of Complementary Code Key (CCK) encoded symbols. The system comprises: a decision feedback equalizer (DFE) structure for simulating an inverse communications channel response and providing an output comprising an estimation of the received symbols, the DFE structure including a forward equalizer path and a feedback equalizer path including a feedback filter; and, a CCK decoder embedded in the feedback path and operating in conjunction with a feedback filter therein for decoding the chips based on intermediate DFE outputs including those chips corresponding to past decoded CCK symbols. Decisions on a symbol chip at a particular time are not made until an entire CCK codeword that the chip belongs to is decoded, thereby reducing errors propagated when decoding the symbols.

[0014] Advantageously, the trellis decoding method is implemented as a computationally efficient 64-state trellis.

[0015] Further benefits and advantages of the invention will become apparent from a consideration of the following detailed description, given with reference to the accompanying drawings, which specify and show preferred embodiments of the invention.

BRIEF DESCRIPTION OF THE DRAWINGS

[0016]FIG. 1 illustrates generally a DFE equalizer structure according to the prior art;

[0017]FIG. 2 depicts the joint DFE and CCK decoding technique according to a first embodiment of the invention;

[0018]FIG. 3 depicts the joint DFE and CCK decoding technique according to a preferred embodiment of the invention; and,

[0019]FIG. 4 depicts the generated trellis structure underlying the joint DFE and CCK decoding technique of the invention.

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

[0020] The present invention is directed to a digital communications system and a computationally efficient decoding structure for decoding data received in the form of symbols modulated according to Complementary Code Keying (CCK) technique. The system of the invention will be described herein for the case of an 11 Mbps digital data stream in accordance with the IEEE 802.11b standard, however, it is understood that skilled artisans may readily apply the principles described herein to other bit stream data rates in accordance with the standard, e.g., 5.5 Mps.

[0021] In a first embodiment of the invention, as shown in FIG. 2, the system includes a receiver device comprising, in part, a Decision Feedback Equalizer (“DFE”) 20 such as the equalizer used in a 802.11b communications receiver. The DFE 20 may be a fractionally spaced decision-feedback equalizer (DFE) having a forward filter 12′ with taps that are fractionally (T/2) spaced. This forward filter 12′ will perform both matched filtering and equalization. The equalizer 20 further includes a feedback filter 16′ that may be sample spaced, i.e., T spaced, where “T” denotes the sample rate, which is also the chip rate, e.g., 11 MHz. The input to the equalizer 20 is assumed to be T/2 spaced, i.e., sampled at 22 MHz. The DFE 20 may be used for all the possible 802.11b communications modes, i.e., 1, 2, 5.5 and 11 Mbps. In the first embodiment, as shown in FIG. 2, the input to the feedback filter section 16 comprises the output of the slicer 14′, which provides an estimate of the true transmitted chips and may include either a BPSK or QPSK slicer, depending on the transmitted mode. Equation (1) describes this structure as follows: $\begin{matrix} {{\overset{\sim}{c}}_{k} = {{\sum\limits_{i = 0}^{L_{f} - 1}{f_{i}r_{{2k} + d_{f} - i}}} + {\sum\limits_{i = 1}^{L_{b}}{b_{i}{\hat{c}}_{k - i}}}}} & (1) \end{matrix}$

[0022] where, f_(i) are the forward equalizer taps, b_(i) are the feedback equalizer taps, r_(k) is the received input stream at T/2 rate, {tilde over (c)}_(k) is the DFE equalizer output at T rate, L_(f) is the length of the forward filter, d_(f) is the delay through the forward filter, L_(b) is the length of the feedback filter, and ĉ_(k) is the slicer output which is an estimate of the true transmitted chip c_(k). As shown in FIG. 2, there is provided a CCK decoder 25 for providing the decoding of the received chips. It should be understood that in other embodiments, the decode element 25 may comprises a typical Barker despreader, for the low-rate modes. The input to the CCK decoder 25 is {tilde over (c)}_(k). It is readily seen that, in this embodiment, equalization and CCK decoding/Barker dispreading are completely separated and, as such, may be subject to propagation errors due to errors made by the slicer.

[0023] For improved performance, in a preferred embodiment, the DFE structure 20′ illustrated in FIG. 3 is implemented. In accordance with the configuration illustrated in FIG. 3, the CCK decoder/Barker despreader device 25′ is embedded into a DFE feedback loop 30 including the feedback filter. Decoding and equalization is done on a block of eight chips for the CCK modes and on eleven chips for DSSS modes. Equation 2) describes the structure for the CCK mode as follows: $\begin{matrix} \begin{matrix} {{{\overset{\sim}{c}}_{k + j} = {{\sum\limits_{i = 0}^{L_{f} - 1}{f_{i}r_{{2{({k + j})}} + d_{f} - i}}} + {\sum\limits_{i = 1}^{L_{b}}{b_{i}{\overset{\sim}{c}}_{k + j - i}}}}},{j = 0},1,{\ldots \quad 7}} \\ {= {{\sum\limits_{i = 0}^{L_{f} - 1}{f_{i}r_{{2{({k + j})}} + d_{f} - i}}} + {\sum\limits_{i = {j + 1}}^{L_{b}}{b_{i}{\hat{c}}_{k + j - i}}} + {\sum\limits_{i = 1}^{j}{b_{i}c_{k + j - i}}}}} \\ {= {s_{k + j} + {\sum\limits_{i = 1}^{j}{b_{i}c_{k + j - i}}}}} \end{matrix} & (2) \end{matrix}$

[0024] where s_(k+j) $\begin{matrix} {s_{k + j} = {{\sum\limits_{i = 0}^{L_{f} - 1}{f_{i}r_{{2{({k + j})}} + d_{f} - i}}} + {\sum\limits_{i = {j + 1}}^{L_{b}}{b_{i}{\hat{c}}_{k + j - i}}}}} & {\quad {{j = 0},{\ldots \quad 7}}} \end{matrix}$

[0025] represents the intermediate DFE equalizer outputs that include, in the feedback filter, only those chips corresponding to past decoded CCK symbols and the $\sum\limits_{i = 1}^{j}{b_{i}c_{k + j - i}}$

[0026] component represents the chips comprising the present transmitted symbol. According to the invention, the CCK decoder 20′ then chooses, from the set of 256 possible codewords, that codeword [c₀,c₁, . . . , c₇] that minimizes the metric set forth in equation 3) as follows: $\begin{matrix} {\sum\limits_{j = 0}^{7}{{s_{k + j} + {\sum\limits_{i = 1}^{j}{b_{i}c_{j - i}}} - c_{j}}}^{2}} & (3) \end{matrix}$

[0027] It is understood that similar equations may be written for the DSSS modes except that blocks of 11 chips at a time would be considered and that there are only 2, or 4 possible 11-chip words.

[0028] The configuration in accordance with the preferred embodiment greatly reduces error propagation, as decisions on the chip at time k are not made until the entire CCK codeword that the chip belongs to is decoded. The complexity of this solution is greater than the configuration in accordance with the first embodiment (FIG. 2), however, according to the preferred embodiment of the invention, a computationally efficient decoding method employing a trellis structure is provided, as will be described.

[0029] According to this method, the variable c=[c₀, c₁ . . . , c₇] represents the 8-symbol CCK codeword. The symbols in the codeword “c” are expressed in terms of the four QPSK phases ø₁, ø₂, ø₃ and ø₄ used to create the CCK codes according to equation 4) as follows: $\begin{matrix} {\underset{\_}{c} = \left\lbrack {^{j{({{\varphi \quad 1} + {\varphi \quad 2} + {\varphi \quad 3} + {\varphi \quad 4}})}},^{j{({{\varphi \quad 1} + {\varphi \quad 3} + {\varphi \quad 4}})}},^{j{({{\varphi \quad 1} + {\varphi \quad 2} + {\varphi \quad 4}})}},{- ^{j{({{\varphi \quad 1} + {\varphi \quad 4}})}}},^{j{({{\varphi \quad 1} + {\varphi \quad 2} + {\varphi \quad 3}})}},^{j{({{\varphi \quad 1} + {\varphi \quad 3}})}},{- ^{j{({{\varphi 1} + {\varphi 2}})}}},{- ^{j{({\varphi \quad 1})}}}} \right\rbrack} & (4) \end{matrix}$

[0030] As the phase ø₁ is common to all the symbols in a codeword, the following definitions for values α₁, α₂ and α₃ are provided according to equation 5) as follows:

α₁=ø₂+ø₃+ø₄

α₂=ø₃+ø₄

α₃=ø₂+ø₄  (5)

[0031] Thus, the CCK codeword C may be re-written in terms of the variables α_(i) and ø₁ according to equation 6) as follows: $\begin{matrix} {\underset{\_}{c} = {^{j\quad \varphi \quad 1}\left\lbrack {^{j\quad \alpha \quad 1},^{j\quad \alpha \quad 2},^{j\quad \alpha \quad 3},{- ^{j\quad {({{\alpha \quad 2} + {\alpha \quad 3} - {\alpha \quad 1}})}}},^{j\quad {({{2\quad \alpha \quad 1} - {\alpha \quad 2} - {\alpha \quad 3}})}},^{j\quad {({{\alpha \quad 1} - {\alpha \quad 3}})}},{- ^{j\quad {({{\alpha \quad 1} - {\alpha \quad 2}})}}},1} \right\rbrack}} & (6) \end{matrix}$

[0032] In other words, the codeword c may be expressed as: c=e^(jφ1) d, where d is a function of α₁, α₂ and α₃ as shown in equation 6). Each of the α_(i) may take on one of 4 values [0, π/2, π, 3π/2] and hence d belongs to a set of 64 possible vectors, whereas c can have 256 possible values. Utilizing a brute force methodology, the embedded CCK decoder may be programmed to choose from the set of 256 possible code words (a number 8 symbols long), that minimizes the metric, and use the corresponding c₀, c₁, . . . , c₇ values. For this brute force minimization, this value would be computed 256 times (for each of the 256 possible combinations that could be transmitted) with the combination that minimizes this metric distance being picked.

[0033] According to the preferred embodiment, however, rather than a brute force methodology, a trellis structure may be used because of the memory effect of the feedback filter in the DFE feedback loop 30 (FIG. 3). That is, the eight intermediate outputs s_(k+j), j=0, 1, . . . , 7, are processed by the trellis to determine the transmitted codeword at time k. Advantageously, as will be described, the dimensionality of a trellis search may be reduced from 256 to 64. That is, as shown in FIG. 4, a trellis structure 100 is generated which represents basically as a state diagram having an initial state 102 _(j=0), whereby, in the case of a multi-path channel and considering only the contribution in the feedback filter from symbols in the present CCK code word, the maximum number of states 102 in a corresponding set 102 _(j=0), . . . , 102 _(j=7) at each corresponding level 103 _(j=0), . . . , 103 _(j=7) (equal to eight (8) levels), grows up to a maximum of sixty-four (64). Preferably, the trellis structure is embodied as an algorithm executing in hardware provided in the combined CCK decoder/equalizer feedback filter structure (FIG. 3), however, it could easily be executed in software.

[0034] In the description of how the programmed trellis structure and algorithm of FIG. 4 operates to process the block of eight symbols s_(k+j), reference is had to equation 3, which sets forth the metric to be minimized and which may be re-written in terms of variables d and ø₁ according to equations 7) and 8) as follows: $\begin{matrix} {\sum\limits_{j = 0}^{7}{{s_{k + j} + {\sum\limits_{i = 0}^{j}{b_{i}c_{j - i}}}}}^{2}} & (7) \end{matrix}$

[0035] where b₀=−1; and, using the relation c_(i)=e^(jφ1)d_(i), the following equation 8) is obtained: $\begin{matrix} \begin{matrix} {{\sum\limits_{j = 0}^{7}{{s_{k + j} + {^{j\quad \varphi \quad 1}{\sum\limits_{1 = 0}^{j}{b_{i}d_{j - i}}}}}}^{2}} = {{\sum\limits_{j = 0}^{7}\left\lbrack s_{k + j} \right.^{2}} + {{\sum\limits_{i = 0}^{j}{b_{i}d_{j - i}}}}^{2} +}} \\ \left. {2\quad {{Re}\left( {s_{k + j}^{*}^{j\quad \varphi \quad 1}{\sum\limits_{i = 0}^{j}{b_{1}d_{j - i}}}} \right)}} \right\rbrack \end{matrix} & (8) \end{matrix}$

[0036] where Re denotes a real part and * denotes complex conjugate. Minimizing the above equation is equivalent to minimizing the metric according to equation 9) as follows: $\begin{matrix} {{\sum\limits_{j = 0}^{7}{{\sum\limits_{i = 0}^{j}{b_{i}d_{j - i}}}}^{2}} + {2\quad {{Re}\left\lbrack {^{j\quad \varphi \quad i}{\sum\limits_{j = 0}^{7}{s_{k + j}^{*}{\sum\limits_{i = 0}^{j}{b_{i}d_{j - i}}}}}} \right\rbrack}}} & (9) \end{matrix}$

[0037] Defining now the term $\chi_{j} = {\sum\limits_{i = 0}^{j}{b_{i}{d_{j - i}.}}}$

[0038] then, the metric to be minimized may be set forth according to equation 10) as follows: $\begin{matrix} {{\sum\limits_{j = 0}^{7}{\chi_{j}}^{2}} + {2\quad {{Re}\left\lbrack {^{j\quad \varphi \quad 1}{\sum\limits_{j = 0}^{7}{s_{k + j}^{*}\chi_{j}}}} \right\rbrack}}} & (10) \end{matrix}$

[0039] Returning to FIG. 4, a state in the trellis 100 is defined by the vector [α₁, α₂, α₃] and a block of eight (8) symbols s_(k+j), j=0, 1, . . . , 7, are processed by the trellis as follows: At each time, j, the following quantities are calculated for each state 102 in the set 102 _(j=0), . . . , 102 _(j=7) as follows: χ_(j), a real-valued m₁(j)=|χ_(j)|² and a complex-valued m₂(j)=s*k+jχ_(j). Substituting these values into equation 10), the metric to be minimized may now be set forth according to equation 11) as follows: $\begin{matrix} {{\sum\limits_{j = 0}^{7}{m_{1}(j)}} + {2\quad {{Re}\left\lbrack {^{j\quad \varphi \quad 1}{\sum\limits_{j = 0}^{7}{m_{2}(j)}}} \right\rbrack}}} & (11) \end{matrix}$

[0040] Thus, for every branch in a trellis path, two (2) quantities need to be computed: a real-valued m₁(j)=|χ_(j)|² and a complex-valued m₂(j)=s*k+jχ_(j). These quantities are then added to the corresponding quantities of the state from which the branch originated. Unlike the trellis decoding in a convolutional code, here there is only one branch coming into any state and hence there is no “survivor path”. At 102 _(j=0) there are 4 possible paths corresponding to the 4 possible values of α₁, at 102 _(j=1) there are 16 possible paths corresponding to the 16 possible combinations of [α₁, α₂], at 102 _(j=2) there are 64 possible paths corresponding to the 64 possible combinations of [α₁, α₂, α₃] and after that the trellis size does not grow since all succeeding values of d_(j) are functions of the same three phases, as shown in equation (6). After the entire codeword has been received, i.e., at the end of the trellis 100 when 102 _(j=7) at level 103 _(j=7), for each of the 64 states the metric set forth in equation 11) is calculated for each of the 4 possible values of ø₁ for a total of 256 values. Then, the state and ø₁ value is chosen that corresponds to the minimum metric. The vector [α₁, α₂, α₃] corresponding to the state with the minimum metric along with the ø₁ value is then used to calculate the transmitted codeword c.

[0041] It should be understood that the extra quantity m₁(j) has to be computed in the equation 11), because, in general, this term will be a function of the codeword and the filter taps. In the absence of multipath, i.e., b₀=−1 and b_(j)=0 elsewhere, it is easy to see that m₁(j)=1 always, and hence does not contribute towards the final metric.

[0042] As shown in FIG. 4, at each state, the trellis structure moves to four (4) other values, depending upon what the so value was because that goes into b₀ (equation 3). Then from each value, the trellis may branch into four other values. It is readily seen that, if at every state 102 a, . . . , 102 n in the trellis there may be four possible inputs corresponding to four different values, then the structure would grow exponentially and basically end up with a number of combinations (states) equal to 4⁸. However, according to the CCK structure, this trellis structure only moves to 64 states (i.e., 102 c, . . . , 102 n) and then saturates. This is because all of the eight symbols may be expressed in terms of just three (phase) values α₁, α₂ and α₃, i.e., each of these three phases can take one of four values so there is 4³=64 possible combinations which makes the trellis structure extremely manageable.

[0043] While it is apparent that the invention herein disclosed is well calculated to fulfill the objects stated above, it will be appreciated that numerous modifications and embodiment may be devised by those skilled in the art, and it is intended that the appended claims cover all such modifications and embodiments as fall within the true spirit and scope of the present invention. 

What is claimed is:
 1. In a communications system including a receiver device for receiving symbols communicated via a communications channel and encoded according to a Complementary Code Key (CCK) chip encoding scheme, a system for decoding received CCK encoded symbols (chips), said system comprising: a decision feedback equalizer (DFE) structure for receiving and equalizing CCK-encoded symbols communicated over a communications channel, and providing an output comprising an estimation of said received symbols, said DFE structure including a forward equalizer path and a feedback equalizer path including a feedback filter; a CCK decoder means embedded in said feedback path and operating in conjunction with a feedback filter therein for decoding said chips, said decoding of CCK chips being based on intermediate DFE outputs including those chips corresponding to past decoded CCK symbols, wherein decisions on a symbol chip at a particular time are not made until an entire CCK codeword that the chip belongs to is decoded, thereby reducing errors propagated when decoding said symbols.
 2. The system according to claim 1, wherein the decoding and equalization are performed on a block of eight 8 chips {tilde over (c)}_(k+j) for CCK modes.
 3. The system according to claim 2, wherein estimated DFE equalizer outputs {tilde over (c)}_(k+j) for CCK mode symbols is governed according to the equation: ${{\overset{\sim}{c}}_{k + j} = {s_{k + j} + {\sum\limits_{i = 1}^{j}{b_{i}c_{k + j - i}}}}},{where}$ $s_{k + j} = {{\sum\limits_{i = 0}^{L_{f} - 1}{f_{i}r_{{2{({k + j})}} + d_{f} - i}}} + {\sum\limits_{i = {j + 1}}^{L_{b}}{b_{i}{\hat{c}}_{k + j - i}}}}$

j=0, . . . 7 and represents the intermediate DFE equalizer outputs that include, in the feedback filter, only those chips corresponding to past decoded CCK symbols, f_(i) are forward equalizer taps, b_(i) are feedback equalizer taps, r_(k) represents a received input stream at a specified rate, L_(f) represents a length of the forward filter, d_(f) represents a delay through the forward filter, L_(b) represents a length of the feedback filter, and ĉ_(k) represents a slicer output which is an estimate of the true transmitted chip c_(k), and the $\sum\limits_{i = 1}^{j}{b_{i}c_{k + j - i}}$

component represents the chips comprising the present transmitted symbol.
 4. The system according to claim 3, wherein the CCK decoder includes means for choosing from a set of possible CCK codewords, a codeword c=[c₀, c₁, . . . c₇] that minimizes a metric comprising: $\sum\limits_{j = 0}^{7}{{{s_{k + j} + {\sum\limits_{i = 1}^{j}{b_{i}c_{j - i}}} - c_{j}}}^{2}.}$


5. The system according to claim 4, wherein the codeword c is represented in terms of variables α_(i) and ø₁ according to c=e^(jφ1) d where d [e^(jα1), e^(jα2), e^(jα3), −e^(j() ^(α2+α3−α1)) , e^(j(2α1−α2−α3), e^(j(α1−α3), −e^(j(α1−α2)), 1] and each of α_(i) comprises one of four (4) values [0, π/2, π, 3π/2], whereby d belongs to a set of 64 possible state vectors, and c may have 256 possible values.
 6. The system according to claim 5, wherein the CCK decoder includes trellis decoding means for generating a trellis structure having a plurality of trellis paths representing possible states of said codeword c, wherein a state in the trellis structure is represented by the vector [α₁, α₂, α₃].
 7. The system according to claim 6, wherein said metric to be minimized is governed according to: ${{\sum\limits_{j = 0}^{7}{\chi_{j}}^{2}} + {2\quad {{Re}\left\lbrack {^{j\quad \varphi \quad 1}{\sum\limits_{j = 0}^{7}{s_{k + j}^{*}\chi_{j}}}} \right\rbrack}\quad {where}\quad \chi_{j}}} = {\sum\limits_{i = 0}^{j}{b_{i}{d_{j - i}.}}}$


8. The system according to claim 7, wherein the metric to be minimized is governed according to ${{\sum\limits_{j = 0}^{7}{m_{1}(j)}} + {2\quad {{Re}\left\lbrack {^{j\quad \varphi \quad 1}{\sum\limits_{j = 0}^{7}{m_{2}(j)}}} \right\rbrack}\quad {where}\quad {m_{1}(j)}}} = {\chi_{j}}^{2}$

and is a real-valued quantity, and m₂(j)=s*k+jχ_(j) and is a complex-valued quantity, said trellis decoder structure including means for processing a block of eight (8) intermediate output symbols s_(k+j), j=0, 1, . . . , 7, including means for calculating, at each time, j, for each branch in a trellis path, said m₁(j) and m₂(j) quantities; and, means for adding m₁(j) and m₂(j) quantities to the corresponding quantities of the state from which the trellis branch originated, whereby the eight intermediate outputs s_(k+j), j=0, 1, . . . , 7, are processed by the trellis to determine the transmitted codeword at time k.
 9. The system according to claim 8, wherein said calculating means includes calculating, for each codeword state, the ${\sum\limits_{j = 0}^{7}{m_{1}(j)}} + {2\quad {{Re}\left\lbrack {^{j\quad \varphi \quad 1}{\sum\limits_{j = 0}^{7}{m_{2}(j)}}} \right\rbrack}}$

metric for each of four φ₁ values [0, π/2, π, 3π/2], said means further choosing a state vector [α₁, α₂, α₃] and φ₁ that results in the minimum metric and calculating the transmitted codeword c accordingly therefrom, wherein a dimensionality of said trellis decoding means is reduced from 256 to
 64. 10. A method for decoding symbols encoded according to a Complementary Code Key (CCK) chip encoding scheme, said method comprising the steps of: a) providing a decision feedback equalizer (DFE) structure for receiving and equalizing CCK-encoded symbols (chips) communicated over a communications channel, said DFE structure further estimating said received symbols for DFE output, said DFE structure including a forward equalizer path and a feedback equalizer path including a feedback filter; b) embedding a CCK decoder means in said feedback path for decoding said chips in conjunction with filter taps of determined for said feedback filter; and, c) decoding of said CCK chips based on intermediate DFE outputs including those chips corresponding to past decoded CCK symbols, wherein decisions on a symbol chip at a particular time are not made until an entire CCK codeword that the chip belongs to is decoded, thereby reducing errors propagated when decoding said symbols.
 11. The method according to claim 10, wherein the decoding and equalization steps are performed on a block of eight 8 chips {tilde over (c)}_(k+j) for CCK modes.
 12. The method according to claim 11, wherein said estimating step includes calculating estimated DFE equalizer outputs {tilde over (c)}_(k+j) for CCK mode symbols according to: ${{\overset{\sim}{c}}_{k + j} = {s_{k + j} + {\sum\limits_{i = 1}^{j}{b_{i}c_{k + j - i}}}}},{where}$ $s_{k + j} = {{\sum\limits_{i = 0}^{L_{f} - 1}{f_{i}r_{{2{({k + j})}} + d_{f} - i}}} + {\sum\limits_{i = {j + 1}}^{L_{b}}{b_{i}{\hat{c}}_{k + j - i}}}}$

j=0, . . . 7 and represents the intermediate DFE equalizer outputs that include, in the feedback filter, only those chips corresponding to past decoded CCK symbols, f_(i) are forward equalizer taps, b_(i) are feedback equalizer taps, r_(k) represents a received input stream at a specified rate, L_(f) represents a length of the forward filter, d_(f) represents a delay through the forward filter, L_(b) represents a length of the feedback filter, and ĉ_(k) represents a slicer output which is an estimate of the true transmitted chip c_(k), and the $\sum\limits_{i = 1}^{j}{b_{i}c_{k + j - i}}$

component represents the chips comprising the present transmitted symbol.
 13. The method according to claim 12, further including the step of: choosing from a set of possible CCK codewords, a codeword c=[c₀, c₁, . . . , c₇] that minimizes a metric comprising: $\sum\limits_{j = 0}^{7}{{{s_{k + j} + {\sum\limits_{i = 1}^{j}{b_{i}c_{j - i}}} - c_{j}}}^{2}.}$


14. The method according to claim 13, wherein the codeword c is represented in terms of variables α_(i) and ø₁ according to c=e^(jφ1) d where d=[e^(jα1), e^(jα2), e^(jα3), −e^(j() ^(α2+α3−α1)) , e^(j(2α1−α2−α3), e^(j(α1−α3)), −e^(j(α1−α2)), 1] and each of α_(i) comprises one of four (4) values [0, π/2, π, 3π/2], whereby d belongs to a set of 64 possible vectors, and c may have 256 possible values.
 15. The method according to claim 14, wherein said decoding step c) further includes the step of generating a trellis structure having a plurality of trellis paths representing possible states of said codeword c, wherein a state in the trellis structure is represented by the vector [α₁, α₂, α₃].
 16. The method according to claim 15, wherein said metric to be minimized is governed according to: ${{\sum\limits_{j = 0}^{7}{\chi_{j}}^{2}} + {2\quad {{Re}\left\lbrack {^{j\quad \varphi \quad 1}{\sum\limits_{j = 0}^{7}{s_{k + j}^{*}\chi_{j}}}} \right\rbrack}\quad {where}\quad \chi_{j}}} = {\sum\limits_{i = 0}^{j}{b_{i}{d_{j - i}.}}}$


17. The method according to claim 16, wherein the metric to be minimized is governed according to ${{\sum\limits_{j = 0}^{7}{m_{1}(j)}} + {2\quad {{Re}\left\lbrack {^{j\quad \varphi \quad 1}{\sum\limits_{j = 0}^{7}{m_{2}(j)}}} \right\rbrack}\quad {where}\quad {m_{1}(j)}}} = {\chi_{j}}^{2}$

and is a real-valued quantity, and m₂(j)=s*k+jχ_(j) and is a complex-valued quantity, said trellis generating step further including the steps of: processing a block of eight (8) intermediate output symbols s_(k+j), j=0, 1, . . . , 7, including means for calculating, at each time, j, for each branch in a trellis path, said m₁(j) and m₂(j) quantities; and, adding said m₁(j) and m₂(j) quantities to the corresponding quantities of the state from which the trellis branch originated, whereby the eight intermediate outputs s_(k+j), j=0, 1, . . . , 7, are processed by the trellis to determine the transmitted codeword at time k.
 18. The method according to claim 17, wherein the calculating step further includes the steps of: calculating, for each codeword state, the ${\sum\limits_{j = 0}^{7}{m_{1}(j)}} + {2\quad {{Re}\left\lbrack {^{j\quad \varphi \quad 1}{\sum\limits_{j = 0}^{7}{m_{2}(j)}}} \right\rbrack}}$

 metric for each of four φ₁ values [0, π/2, π, 3π/2]; and, choosing a state vector [α₁, α₂, α₃] and φ₁ that results in the minimum metric and calculating the transmitted codeword c accordingly therefrom, wherein a dimensionality of said trellis structure is reduced from 256 to
 64. 19. A receiver device for receiving symbols communicated via a communications channel, said symbols encoded according to a Complementary Code Key (CCK) chip encoding scheme, said receiver device comprising: a decision feedback equalizer (DFE) structure for receiving and equalizing CCK-encoded symbols (chips) communicated over a communications channel, and providing an output comprising an estimation of said received symbols, said DFE structure including a forward equalizer path and a feedback equalizer path including a feedback filter; a CCK decoder means embedded in said feedback path and operating in conjunction with a feedback filter therein for decoding said chips, said decoding of CCK chips being based on intermediate DFE outputs including those chips corresponding to past decoded CCK symbols, wherein decisions on a symbol chip at a particular time are not made until an entire CCK codeword that the chip belongs to is decoded, thereby reducing errors propagated when decoding said symbols.
 20. The receiver device according to claim 19, wherein the decoding and equalization are performed on a block of eight 8 chips {tilde over (c)}_(k+j) for CCK modes.
 21. The receiver device according to claim 20, wherein estimated DFE equalizer outputs {tilde over (c)}_(k+j) for CCK mode symbols is governed according to the equation: ${{\overset{\sim}{c}}_{k + j} = {s_{k + j} + {\sum\limits_{i = 1}^{j}{b_{i}c_{k + j - i}}}}},{where}$ $s_{k + j} = {{\sum\limits_{i = 0}^{L_{f} - 1}{f_{i}r_{{2{({k + j})}} + d_{f} - i}}} + {\sum\limits_{i = {j + 1}}^{L_{b}}{b_{i}{\hat{c}}_{k + j - i}}}}$

j=0, . . . 7 and represents the intermediate DFE equalizer outputs that include, in the feedback filter, only those chips corresponding to past decoded CCK symbols, f_(i) are forward equalizer taps, b_(i) are feedback equalizer taps, r_(k) represents a received input stream at a specified rate, L_(f) represents a length of the forward filter, d_(f) represents a delay through the forward filter, L_(b) represents a length of the feedback filter, and ĉ_(k) represents a slicer output which is an estimate of the true transmitted chip c_(k), and the $\sum\limits_{i = 1}^{j}{b_{i}c_{k + j - i}}$

component represents the chips comprising the present transmitted symbol.
 22. The receiver device according to claim 21, wherein the CCK decoder includes means for choosing from a set of possible CCK codewords, a codeword c=[c₀, c₁, . . . , c₇] that minimizes a metric comprising: $\sum\limits_{j = 0}^{7}{{{s_{k + j} + {\sum\limits_{i = 1}^{j}{b_{i}c_{j - i}}} - c_{j}}}^{2}.}$


23. The receiver device according to claim 22, wherein the codeword c is represented in terms of variables α_(i) and ø₁ according to c=e^(jφ1) d where d=[e^(jα1), e^(jα2), e^(jα3), −e^(j() ^(α2+α3−α1)) , e^(j(2α1−α2−α3), e^(j(α1−α3)), −e^(j(α1−α2)), 1] and each of α_(i) comprises one of four (4) values [0, π/2, π, 3π/2], whereby d belongs to a set of 64 possible vectors, and c may have 256 possible values.
 24. The receiver device according to claim 23, wherein the CCK decoder includes trellis decoding means for generating a trellis structure having a plurality of trellis paths representing possible states of said codeword c, wherein a state in the trellis structure is represented by the vector [α₁, α₂, α₃].
 25. The receiver device according to claim 24, wherein said metric to be minimized is governed according to: ${{\sum\limits_{j = 0}^{7}{\chi_{j}}^{2}} + {2\quad {{Re}\left\lbrack {^{j\quad \varphi \quad 1}{\sum\limits_{j = 0}^{7}{s_{k + j}^{*}\chi_{j}}}} \right\rbrack}\quad {where}\quad \chi_{j}}} = {\sum\limits_{i = 0}^{j}{b_{i}{d_{j - i}.}}}$


26. The receiver device according to claim 25, wherein the metric to be minimized is governed according to ${\sum\limits_{j = 0}^{7}{m_{1}(j)}} + {2\quad {{Re}\left\lbrack {^{j\quad \varphi \quad 1}{\sum\limits_{j = 0}^{7}{m_{2}(j)}}} \right\rbrack}}$

where m₁(j)=|χ_(j)χ² and is a real-valued quantity, and m₂(j)=s*k+jχ_(j) and is a complex-valued quantity, said trellis decoder structure including means for processing a block of eight (8) intermediate output symbols s_(k+j), j=0, 1, . . . , 7, including means for calculating, at each time, j, for each branch in a trellis path, said m₁(j) and m₂(j) quantities; and, means for adding m₁(j) and m₂(j) quantities to the corresponding quantities of the state from which the trellis branch originated, whereby the eight intermediate outputs s_(k+j), j=0, 1, . . . , 7, are processed by the trellis to determine the transmitted codeword at time k.
 27. The receiver device according to claim 26, wherein said calculating means includes calculating, for each codeword state, the ${\sum\limits_{j = 0}^{7}{m_{1}(j)}} + {2{{Re}\left\lbrack {^{j\quad \varphi \quad 1}{\sum\limits_{j = 0}^{7}{m_{2}(j)}}} \right\rbrack}}$

metric for each of four φ₁ values [0, π/2, π, 3π/2], said means further choosing a state vector [α₁, α₂, α₃] and φ₁ that results in the minimum metric and calculating the transmitted codeword c accordingly therefrom, wherein a dimensionality of said trellis decoding means is reduced from 256 to
 64. 